#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
using namespace std;
template <typename K, typename V = __gnu_pbds::null_type>
using tree = __gnu_pbds::tree<K, V, less<K>, __gnu_pbds::rb_tree_tag, __gnu_pbds::tree_order_statistics_node_update>;
using llong = long long;
auto isz = [](const auto& c) { return int(c.size()); };
mt19937 rng((size_t) make_shared<char>().get());
#ifndef _LIB_FASTIO_
#define _LIB_FASTIO_
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wall"
#pragma GCC diagnostic ignored "-Wextra"
#pragma GCC diagnostic ignored "-Wconversion"
/** Fast allocation */
#ifdef FAST_ALLOCATOR_MEMORY
int allocator_pos = 0;
char allocator_memory[(int)FAST_ALLOCATOR_MEMORY];
inline void * operator new ( size_t n ) {
char *res = allocator_memory + allocator_pos;
allocator_pos += n;
assert(allocator_pos <= (int)FAST_ALLOCATOR_MEMORY);
return (void *)res;
}
inline void operator delete ( void * ) noexcept { }
//inline void * operator new [] ( size_t ) { assert(0); }
//inline void operator delete [] ( void * ) { assert(0); }
#endif
/** Fast input-output */
/** Read */
static const int buf_size = 4096;
static unsigned char buf[buf_size];
static int buf_len = 0, buf_pos = 0;
inline bool isEof() {
if (buf_pos == buf_len) {
buf_pos = 0, buf_len = fread(buf, 1, buf_size, stdin);
if (buf_pos == buf_len)
return 1;
}
return 0;
}
inline int getChar() {
return isEof() ? -1 : buf[buf_pos++];
}
inline int peekChar() {
return isEof() ? -1 : buf[buf_pos];
}
inline bool seekEof() {
int c;
while ((c = peekChar()) != -1 && c <= 32)
buf_pos++;
return c == -1;
}
inline void skipBlanks() {
while (!isEof() && buf[buf_pos] <= 32U)
buf_pos++;
}
inline int readChar() {
int c = getChar();
while (c != -1 && c <= 32)
c = getChar();
return c;
}
inline unsigned int readUInt() {
int c = readChar();
unsigned int x = 0;
while ('0' <= c && c <= '9')
x = x * 10 + c - '0', c = getChar();
return x;
}
template <class T = int>
inline T readInt() {
int s = 1, c = readChar();
T x = 0;
if (c == '-')
s = -1, c = getChar();
else if (c == '+')
c = getChar();
while ('0' <= c && c <= '9')
x = x * 10 + c - '0', c = getChar();
return s == 1 ? x : -x;
}
inline long long readLong() {
return readInt<long long>();
}
inline double readDouble() {
int s = 1, c = readChar();
double x = 0;
if (c == '-')
s = -1, c = getChar();
while ('0' <= c && c <= '9')
x = x * 10 + c - '0', c = getChar();
if (c == '.') {
c = getChar();
double coef = 1;
while ('0' <= c && c <= '9')
x += (c - '0') * (coef *= 1e-1), c = getChar();
}
return s == 1 ? x : -x;
}
inline void readWord(char *s) {
int c = readChar();
while (c > 32)
*s++ = c, c = getChar();
*s = 0;
}
inline void readWord(string &s) {
s.clear();
int c = readChar();
while (c > 32)
s += c, c = getChar();
}
inline bool readLine(char *s) {
int c = getChar();
while (c != '\n' && c != -1)
*s++ = c, c = getChar();
*s = 0;
return c != -1;
}
inline bool readLine(string &s) {
s.clear();
int c = getChar();
while (c != '\n' && c != -1)
s += c, c = getChar();
return c != -1;
}
/** Write */
static int write_buf_pos = 0;
static char write_buf[buf_size];
inline void writeChar(int x) {
if (write_buf_pos == buf_size)
fwrite(write_buf, 1, buf_size, stdout), write_buf_pos = 0;
write_buf[write_buf_pos++] = x;
}
inline void flush() {
if (write_buf_pos) {
fwrite(write_buf, 1, write_buf_pos, stdout), write_buf_pos = 0;
fflush(stdout);
}
}
template <class T>
inline void writeInt(T x, char end = 0, int output_len = -1) {
if (x < 0)
writeChar('-'), x = -x;
char s[24];
int n = 0;
while (x || !n)
s[n++] = '0' + x % 10, x /= 10;
while (n < output_len)
s[n++] = '0';
while (n--)
writeChar(s[n]);
if (end)
writeChar(end);
}
inline void writeWord(const char *s) {
while (*s)
writeChar(*s++);
}
inline void writeWord(const string& s) {
writeWord(s.c_str());
}
inline void writeDouble(double x, int output_len = 11) {
if (x < 0)
writeChar('-'), x = -x;
int t = (int)x;
writeInt(t), x -= t;
writeChar('.');
for (int i = output_len - 1; i > 0; i--) {
x *= 10;
t = std::min(9, (int)x);
writeChar('0' + t), x -= t;
}
x *= 10;
t = std::min(9, (int)(x + 0.5));
writeChar('0' + t);
}
/** Buffer flusher */
static struct buffer_flusher_t {
~buffer_flusher_t() {
flush();
}
} buffer_flusher;
/** Reader and writer */
struct fast_reader {
fast_reader& operator>>(int& n) {
n = readInt(); return *this;
}
fast_reader& operator>>(unsigned int& n) {
n = readUInt(); return *this;
}
fast_reader& operator>>(llong& n) {
n = readLong(); return *this;
}
fast_reader& operator>>(double& n) {
n = readDouble(); return *this;
}
fast_reader& operator>>(float& n) {
n = (float) readDouble(); return *this;
}
fast_reader& operator>>(string& s) {
readWord(s); return *this;
}
fast_reader& operator>>(char& c) {
c = (char) readChar(); return *this;
}
template<typename T>
fast_reader& operator>>(vector<T>& a) {
for (T& i : a) {
(*this) >> i;
}
return *this;
}
} f_reader;
struct fast_writer {
template<typename T>
fast_writer& operator<<(T n) {
writeInt(n); return *this;
}
fast_writer& operator<<(double n) {
writeDouble(n); return *this;
}
fast_writer& operator<<(float n) {
writeDouble(n); return *this;
}
fast_writer& operator<<(const string& s) {
writeWord(s); return *this;
}
fast_writer& operator<<(const char* s) {
writeWord(s); return *this;
}
fast_writer& operator<<(char c) {
writeChar(c); return *this;
}
template<typename T>
fast_writer& operator<<(const vector<T>& a) {
for (size_t i = 0; i < a.size(); ++i) {
if (i) {
(*this) << ' ';
}
(*this) << a[i];
}
return *this;
}
void flush() {
::flush();
}
} f_writer;
#define cin f_reader
#define cout f_writer
#pragma GCC diagnostic pop
#endif //_LIB_FASTIO_
#ifndef _LIB_UTILS_
#define _LIB_UTILS_
template <typename T, T val = T()>
auto make_vector(size_t d) {
return vector<T>(d, val);
}
template <typename T, T val = T(), typename ...Ds>
auto make_vector(size_t d, Ds... ds) {
return vector<decltype(make_vector<T, val>(ds...))>(d, make_vector<T, val>(ds...));
}
#endif //_LIB_UTILS_
void solve();
int main(int argc, char** argv) {
#ifdef VSE
if (argc > 1) assert(freopen(argv[1], "r", stdin));
rng.seed(0);
#endif
#ifndef cin
ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0);
#endif
int t = 1;
// cin >> t;
for (int it = 0; it < t; it++) {
solve();
}
return 0;
}
void solve() {
int n;
cin >> n;
vector<int> a(n);
cin >> a;
vector<int> p(n);
p[0] = 1;
for (int i = 1; i < n; i++) {
if (a[i] > a[i - 1]) {
p[i] = p[i - 1] + 1;
} else {
p[i] = 1;
}
}
vector<int> s(n);
s[n - 1] = 1;
for (int i = n - 2; i >= 0; i--) {
if (a[i] < a[i + 1]) {
s[i] = s[i + 1] + 1;
} else {
s[i] = 1;
}
}
int ans = *max_element(begin(p), end(p));
ans = max(ans, *max_element(begin(s), end(s)));
for (int i = 1; i + 1 < n; i++) {
if (a[i - 1] < a[i + 1]) {
ans = max(ans, p[i - 1] + s[i + 1]);
}
}
cout << ans << "\n";
}
622. Design Circular Queue | 814. Binary Tree Pruning |
791. Custom Sort String | 787. Cheapest Flights Within K Stops |
779. K-th Symbol in Grammar | 701. Insert into a Binary Search Tree |
429. N-ary Tree Level Order Traversal | 739. Daily Temperatures |
647. Palindromic Substrings | 583. Delete Operation for Two Strings |
518. Coin Change 2 | 516. Longest Palindromic Subsequence |
468. Validate IP Address | 450. Delete Node in a BST |
445. Add Two Numbers II | 442. Find All Duplicates in an Array |
437. Path Sum III | 436. Find Right Interval |
435. Non-overlapping Intervals | 406. Queue Reconstruction by Height |
380. Insert Delete GetRandom O(1) | 332. Reconstruct Itinerary |
368. Largest Divisible Subset | 377. Combination Sum IV |
322. Coin Change | 307. Range Sum Query - Mutable |
287. Find the Duplicate Number | 279. Perfect Squares |
275. H-Index II | 274. H-Index |